<!--
  * 首页 用户头部信息
  *
  * @Author:    dcsoft
  * @Date:      2022-09-12 22:34:00
  * @Wechat:    dctech
  * @Email:     dctech@dctech2020.com
  *@Copyright 山东东晨软件科技有限公司(https://www.dctech2020.com),since 2015
  *
-->
<template>
  <div class="user-header">
    <a-page-header :title="welcomeSentence">
      <template #subTitle>
        <span style="color: #666; margin-left: 20px">所属部门：研发中心 </span>
      </template>
      <template #extra>
        <p style="color: #333">{{ dayInfo }}</p>
      </template>
      <a-row class="content">
        <span class="left-content">
          <p class="last-login-info"><AlertOutlined />{{ lastLoginInfo }}</p>
          <!-- <a class="sentence" href="https://zhuoda.vip/soup" target="_blank">
            <smile-outlined spin /> {{ heartSentence }}
          </a> -->
        </span>
        <div class="weather">
          <iframe
            width="100%"
            scrolling="no"
            height="50"
            frameborder="0"
            allowtransparency="true"
            src="//i.tianqi.com/index.php?c=code&id=12&icon=1&num=3&site=12"
          ></iframe>
        </div>
      </a-row>
    </a-page-header>
  </div>
</template>
<script setup>
import _ from "lodash";
import { Lunar, Solar } from "lunar-javascript";
import uaparser from "ua-parser-js";
import { computed } from "vue";
import heartSentenceArray from "./heart-sentence";
import { useUserStore } from "/@/store/modules/system/user";

const userStore = useUserStore();

const departmentName = computed(() => userStore.departmentName);

// 欢迎语
const welcomeSentence = computed(() => {
  let sentence = "";
  let now = new Date().getHours();
  if (now > 0 && now <= 6) {
    sentence = "午夜好，";
  } else if (now > 6 && now <= 11) {
    sentence = "早上好，";
  } else if (now > 11 && now <= 14) {
    sentence = "中午好，";
  } else if (now > 14 && now <= 18) {
    sentence = "下午好，";
  } else {
    sentence = "晚上好，";
  }
  return sentence + userStore.$state.actualName;
});

//上次登录信息
const lastLoginInfo = computed(() => {
  let info = "";
  if (userStore.$state.lastLoginTime) {
    info = info + "上次登录:" + userStore.$state.lastLoginTime;
  }

  if (userStore.$state.lastLoginUserAgent) {
    let ua = uaparser(userStore.$state.lastLoginUserAgent);
    info = info + "; 设备:";
    if (ua.browser.name) {
      info = info + " " + ua.browser.name;
    }
    if (ua.os.name) {
      info = info + " " + ua.os.name;
    }
    let device = ua.device.vendor ? ua.device.vendor + ua.device.model : null;
    if (device) {
      info = info + " " + device + ";";
    }
  }

  if (userStore.$state.lastLoginIpRegion) {
    info = info + "; " + userStore.$state.lastLoginIpRegion;
  }
  if (userStore.$state.lastLoginIp) {
    info = info + "; " + userStore.$state.lastLoginIp;
  }
  return info;
});

//日期、节日、节气
const dayInfo = computed(() => {
  //阳历
  let solar = Solar.fromDate(new Date());
  let day = solar.toString();
  let week = solar.getWeekInChinese();
  //阴历
  let lunar = Lunar.fromDate(new Date());
  let lunarMonth = lunar.getMonthInChinese();
  let lunarDay = lunar.getDayInChinese();
  //节气
  let jieqi = lunar.getPrevJieQi().getName();
  let next = lunar.getNextJieQi();
  let nextJieqi = next.getName() + " " + next.getSolar().toYmd();

  return `${day} 星期${week}，农历${lunarMonth}${lunarDay}（当前${jieqi}，${nextJieqi} ）`;
});

// 毒鸡汤
const heartSentence = computed(() => {
  return heartSentenceArray[_.random(0, heartSentenceArray.length - 1)];
});
</script>
<style scoped lang="less">
.user-header {
  width: 100%;
  background-color: #fff;
  margin-bottom: 10px;

  .left-content {
    width: calc(100% - 420px);
    h3 {
      color: rgba(0, 0, 0, 0.75);
    }
  }

  .content {
    display: flex;
    justify-content: space-between;
    .weather {
      width: 400px;
    }
  }

  .last-login-info {
    font-size: 13px;
    color: #333;
    overflow-wrap: break-word;
    padding: 0;
    margin: 1px 0 0 0;
  }

  .sentence {
    display: block;
    font-size: 12px;
    color: #acacac;
    overflow-wrap: break-word;
    padding: 5px 0 0 0;
    margin: 6px 0 0 0;
  }
  .sentence:hover {
    cursor: pointer;
    text-decoration: underline;
  }
}
</style>
